/*
This file is part of CanFestival, a library implementing CanOpen Stack.

Copyright (C): Edouard TISSERANT and Francis DUPIN

See COPYING file for copyrights details.

This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/

#include "Slave.h"
#include "Master.h"
#include "TestMasterSlave.h"
#include "can_driver.h"

extern s_BOARD SlaveBoard;
/*****************************************************************************/
void TestSlave_heartbeatError(CO_Data* d, UNS8 heartbeatID)
{
    eprintf("TestSlave_heartbeatError %d\n", heartbeatID);
}

void TestSlave_initialisation(CO_Data* d)
{
    eprintf("TestSlave_initialisation\n");
}

void TestSlave_preOperational(CO_Data* d)
{
    eprintf("TestSlave_preOperational\n");
}

void TestSlave_operational(CO_Data* d)
{
    eprintf("TestSlave_operational\n");
}

void TestSlave_stopped(CO_Data* d)
{
    eprintf("TestSlave_stopped\n");
}

void TestSlave_post_sync(CO_Data* d)
{
    eprintf("TestSlave_post_sync\n");
    SlaveMap1 = 1;
    SlaveMap2 = 1;
    SlaveMap3 = 0;
    SlaveMap4 = 0;
    SlaveMap5 = 1;
    SlaveMap6 = 0;
    SlaveMap7 = 1;
    SlaveMap8 = 0;
    SlaveMap9 = 16;
    SlaveMap10 = 0xff00ff00;
    SlaveMap11 = 0xabcd;
    SlaveMap12 += SlaveMap12 > 0x80 ? 0 : 1;
    eprintf("Slave: %d %d %d %d %d %d %d %d %d %x %x %d %d \n",
            SlaveMap1,
            SlaveMap2,
            SlaveMap3,
            SlaveMap4,
            SlaveMap5,
            SlaveMap6,
            SlaveMap7,
            SlaveMap8,
            SlaveMap9,
            SlaveMap10,
            SlaveMap11,
            SlaveMap12,
            SlaveMap13);
}

void TestSlave_post_TPDO(CO_Data* d)
{
    SlaveMap13 += 1;
    eprintf("TestSlave_post_TPDO\n");
    /* send an error and recover inmediately every 12 cycles */
    if (SlaveMap13 % 12 == 0)
    {
        EMCY_setError(&TestSlave_Data, 0x4200, 0x08, 0x0000);
        EMCY_errorRecovered(&TestSlave_Data, 0x4200);
    }
}

void TestSlave_storeODSubIndex(CO_Data* d, UNS16 wIndex, UNS8 bSubindex)
{
    /*TODO :
     * - call getODEntry for index and subindex,
     * - save content to file, database, flash, nvram, ...
     *
     * To ease flash organisation, index of variable to store
     * can be established by scanning d->objdict[d->ObjdictSize]
     * for variables to store.
     *
     * */
    eprintf("TestSlave_storeODSubIndex : %4.4x %2.2x\n", wIndex,  bSubindex);
}

void TestSlave_post_emcy(CO_Data* d, UNS8 nodeID, UNS16 errCode, UNS8 errReg)
{
    eprintf("Slave received EMCY message. Node: %2.2x  ErrorCode: %4.4x  ErrorRegister: %2.2x\n", nodeID, errCode, errReg);
}
